//
// Created by sjjmw on 3/24/2022.
//
#include "iostream"
#include "vector"
#include "list"
#include "algorithm"
#include "string"
#include "unordered_map"
#include "cmath"
#include<iomanip>
#include "string"
char not_sushu[50000];
struct Sol{
    void handle(int n){
//        int lastsushu=2;
        int cnt=0;
        for(int i=5;i<=n;i++){
            if(!not_sushu[i]&&!not_sushu[i-2]){
                cnt++;
            }
        }
        printf("%d\n",cnt);
    }
};
int main(){
    int a,b,c;
//    not_sushu[2]=0;
    for(int i=2;i<50000;i++){
        if(!not_sushu[i]){
            for(int j=i*2;j<50000;j+=i){
                not_sushu[j]=1;
            }
        }
    }
    while (std::cin>>a){
        if(a<0){
            break;
        }
        Sol().handle(a);
//        handle(a,b);
    }
    return 0;
}